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INTRODUCTION 



SECTION 



1-1. GENERAL 

The HP 12732A Flexible Disc Subsystem Diagnostic verifies proper operation and tests for 
faults of the HP 12732A Flexible Disc Subsystem used with the HP 21MX M-Series and 
E-Series Computers. The program consists of 11 standard tests, two optional tests, and an 
Operator Design Section (OPDSN) which includes a disc formatting subprogram. Test options 
are selected in the S Register which is monitored for halt conditions and message outputs. 
Standard tests are covered in section four and OPDSN is covered in section five. 



1-2. REQUIRED HARDWARE 

The required hardware consists of the following: 

a. An HP 21MX M-Series or E-Series Computer with at least 8K-words of memory. Notes: 
Disable Remote Program Load (RPL) feature of HP 21MX E-Series Computer. DCPC 
(DMA) is required for the HP 21 MX M-Series and is optional for the HP 21MX E-Series. 

b. An HP 12732A Flexible Disc Subsystem consisting of: 

(1) An HP 9885M Flexible Disc Controller/Drive. 

(2) An HP 12735-60001 Microcircuit Interface Card (control channel). 

(3) An HP 12735-60002 Microcircuit Interface Card (data channel). 

(4) An HP 12735-60003 Dual-hooded Connecting Cable. 

c. A program loading device. 

d. A console device. 

Optional hardware consists of the following: 

a. A line printer. 

b. One to three HP 12733A Slave Flexible Disc Drives including: 

(1) An HP 9885S Slave Flexible Disc Drive. 

(2) An HP 09885-61617 Chaining Cable. 
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Introduction 

1-3. SOFTWARE REQUIREMENTS 

The following software is required: 

a. The Diagnostic Configurator, absolute binary program, part no. 24296-60001. Reference 
Manual, part no. 02100-90157, is optional. 

b. HP 12732A Flexible Disc Subsystem Diagnostic, absolute binary program, part no. 
12732-16003. Furnished on paper tape, initialized flexible disc (part no. 12732-13401)*, 
and cartridge tape (part no. 24396-13308). 

The diagnostic serial number (DSN) for this diagnostic is 111104 (octal) and is contained in 
memory location 126 (octal). 



1-4. TEXT CONVENTIONS 

All halt codes, select codes, and addresses used in this manual are octal unless specifically 
shown otherwise. The abbreviations used are listed below: 

DCPC — Dual Channel Port Controller (same as DMA). 

DMA — Direct Memory Access (same as DCPC). 

DSN — Diagnostic Serial Number. 

I/O — Input/Output. 

OPDSN — Operator Design Section. 

Input Buffer — Software buffer input to computer (output from disc drive). 

Output Buffer — Software buffer output from computer (input to disc drive). 



*The Initialized Flexible Disc contains files %DSKET and IMFLEX which can be transferred 
by the File Manager STORE command (consult the appropriate RTE manual for operating 
instructions). The file IMFLEX cannot be read directly by the Diagnostic Configurator, 
therefore it must be transferred to a diagnostic input medium (e.g., a magnetic tape cartridge) 
before use. 
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SECTION 



2-1. ORGANIZATION 

This diagnostic program consists of Initialization and Control sections, 11 standard tests, two 
optional tests, and an operator design section (OPDSN). The Initialization and Control 
sections accept the select codes and options entered in the S-Register and provide halts and 
message outputs. The standard and optional tests are described in section IV and the OPDSN 
in section V. 



2-2 TEST CONTROL AND EXECUTION 

The diagnostic outputs a title message "HP 12732 FLEXIBLE DISC DIAGNOSTIC" to the 
console device and then executes the tests according to the options selected on the S-Register. 
The diagnostic keeps count of the number of passes that have been completed and will output 
the pass count at the completion of each pass (if S-Register bit 10 is clear). At the end of each 
pass the computer will halt (displaying 102077) and the pass count will be in the A-Register (if 
S-Register bit 12 is clear). Press RUN to execute another pass. The count is cleared whenever 
the program is restarted. 

Standard tests (0, 1, 2, and 4-11) are run sequentially in each diagnostic pass (bits 3 and 9 
clear). User selection of tests is with bit 9 set. The computer halts displaying 102075 and then 
desired tests are selected by setting corresponding bits in the A-Register. User test selection 
allows Test 03 (Verify) and Test 12 (Non-DMA Modes) to be executed. 

The OPDSN test programming section is selected by setting S-Register bit 3 (bit 9 clear). The 
console device responds with the message H030 OPDSN. OPDSN programming is similar to 
programming in the BASIC language using sequentially numbered statements and non- 
numbered immediately executable commands. Test program routines are entered statement- 
by-statement into the console device and they are executed as a program by entering the 
command GO. Statements can be altered, deleted, or inserted by integer line numbers as in 
BASIC programming. 

OPDSN also allows the selection of the standard and optional tests from through 12 through 
the console device by programming TEST XX, where XX is the desired test number, for one or 
more tests. Format altering operations in the OPDSN and standard tests require that 
S-Register bits 0, 1, 4, and 5 remain set while the test is in progress. 



2-3. MESSAGE REPORTING 

There are two types of messages: error and information. Error messages are used to inform the 
operator when the subsystem fails to respond correctly to a given control command or test 
sequence. Information messages are used to inform the operator of the progress of the 
diagnostic, or to instruct the operator to perform some operation related to the function 
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of the unit. In the latter case, an associated halt will occur to allow the operator time to 
perform the function. To continue the operator must press RUN. The printed or displayed 
message will be preceded by the letter E for error and the letters H or I for information. The 
letter is followed by a printed message number which corresponds to the octal halt code 
according to the following scheme: 



HALT CODE 


PRINTED MESSAGE NO. 


102000 to 102067 
106000 to 106067 
103000 to 103067 
107000 to 107067 


000 to 067 
100 to 167 
200 to 267 
300 to 367 



The two least-significant digits of this message number are the same as the last two octal 
digits of an associated halt code. 

Example — Error with halt 

Message: E020 PRESET DID NOT SET FLAG 

Halt Code: 102020 (Display Register) 

Example — Information with halt 

Message: H056 TURN OFF MASTER, PRESS RUN 

Halt Code: 102056 (Display Register) 

Example — Information without halt 

Message: HlOl NO DMA 

Halt Code: None 

Error messages can be suppressed by setting S-Register bit 11 and error halts can be 
suppressed by setting S-Register bit 14. Information messages prefixed by H are suppressed by 
setting S-Register bit 10. Information messages prefixed by I cannot be suppressed. 

2-4. PROGRAM LIMITATIONS 

Subsystem capability for receiving, passing, and denying priority (priority logic string) is not 
completely tested by this diagnostic. If the subsystem does not receive priority (i.e. PRH for the 
next lower select code) an error E014 NO INT will occur. To check this, remove an interface of 
a lower select code and run TEST 00 (CARD). The above error should occur. Checking the 
subsystem's ability to pass or deny priority is beyond the scope of this diagnostic. 

Exact timing of I/O operations and flags is not implemented in this diagnostic. However, a 
worst-case time limit is always established for each operation. If this limit is exceeded before 
the device flag signals a completion, a time-out error message (*T0*) will occur. 

The ability of the disc drive controller to report two error conditions is not tested by the Error 
Status Test (ERRR routine), since these errors cannot be forced programmatically (they only 
exist when the disc is physically damaged). These errors are: 
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a. Data checkword Error. 

b. Verify Error. 

The status bits for these errors are given in Appendix A. 

The Error Status Test (Test 04) assumes that a Slave Drive is present. Therefore, if a Slave 
Drive is not present, an error message ElOO will be given. Ignore this message if there is no 
Slave Drive and press RUN to continue 

The interface card test (OPDSN program statement CARD) does not check all functions of the 
cards. More thorough testing can be accomplished with the General Purpose Register (GPR) 
Diagnostic, part no. 24391-16001. Instructions for the GPR diagnostic are covered in the 
General Purpose Register Diagnostic Reference Manual, part no. 24391-90001. (Note: The GPR 
diagnostic requires changing card jumpers. Be sure to replace them for HP 12732 A subsystem 
operation as described in the HP 12732AI12733A Flexible Disc Operating and Service Manual, 
part no. 12732-90005.) 
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3-1. OPERATING PROCEDURE 

Before running the diagnostic, check to be sure that the computer interfaces are properly 
installed. Also check that the interface cable, part no. 12732-60003, is installed and firmly 
attached to the two interface cards and the HP 9885M Flexible Disc Drive. To configure the 
diagnostic prior to running the tests, follow the flowchart provided in figure 3-1. The 
configuration procedure uses the Diagnostic Configurator, part no. 24296-60001. If additional 
information is required on the diagnostic configurator, refer to the Diagnostic Configurator 
Reference Manual, part no. 02100-90157. 



3-2. RUNNING THE DIAGNOSTIC 

The program configuration S-Register setting is given in table 3-1 for entering the Select Code 
of the Control Interface PCA (FLEX DISK I/Fl LOWER SEL) into bits 0-5. Then PRESET, 
RUN. After halt 102074, the program options listed in table 3-2 are entered into the S 
Register. These options are discussed below. 

At the completion of each pass of the diagnostic tests, the pass count is output to the console for 
operator information. If S-Register bit 12 was not selected (loop on diagnostic), the computer 
will halt with octal 102077 in the Display Register. At this point the A Register contains the 
pass count. The operator can press RUN to execute another pass. 

Setting bit 12 loops the diagnostic and suppresses operator intervention in tests and 4. 
Setting bit 8 suppresses operator intervention without causing the diagnostic to loop. If bit 13 
is set while the test is running, that test will loop until bit 13 is cleared. If bit 15 is set while 
the tests are running, the computer will halt at the completion of the current test with the test 
number in the A Register. If the Diagnostic Configurator was configured for a line printer, the 
setting of S-Register bit 7 will cause all information printed on the console to also be output to 
the line printer. 

If a trap cell halt occurs (106077) the user must determine the cause of the unexpected 
interrupt or transfer of control to the location shown in the M Register. The program may need 
to be reloaded to continue. Refer to Appendix B for information on halts and messages. 

No format altering operations are permitted unless S-Register bits 0, 1, 4, and 5 are all set. 
Refer to table 3-3 for the standard tests and OPDSN statements which are affected. 



3-3. TEST SELECTION BY OPERATOR 

For a standard test sequence of one pass, none of the S-Register bits are set. Press PRESET, 
and RUN. 
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To select only certain tests, set S-Register bit 9 when the program options are to be selected 
(halt 102074). Press PRESET, and RUN. The computer halts with 102075 displayed. Enter the 
desired tests by bit number in the- A Register. Setting bits XX of the A Register will cause 
standard test XX to be executed. Press PRESET, and RUN. Setting S-Register bit 9 while a 
test is running will abort that test, and the computer will halt 102075 to allow test selection. 
(The A Register will contain the last selected set of tests.) The standard tests run only on the 
drive selected as drive 0. Any drive (master or slave) may be selected as drive by setting a 
rear panel control as described in the HP 12732AI12733A Operating and Service Manual, part 
no. 12732-90005. (For programmed operation of any drive number from 0-3, go to the OPDSN 
section of the diagnostic.) 

To enter the OPDSN program when program options are to be selected, set S-Register bit 3 (bit 
9 clear), press PRESET and RUN. Setting S-Register bit 3 while a test is running will abort 
that test. The message H030 OPDSN will be output to the console, and OPDSN statements 
may be entered. 

Using OPDSN, tests may be executed in any order by setting up a program with statement 
numbers for TEST XX through TEST YY. For example the following program runs tests 7, 4 
and 11 in that order: 

10 TEST 7 
20 TEST 4 
30 TEST 11 
GO 

There are four default conditions which occur when executing each standard test not under 
OPDSN and on GO under OPDSN. These are the following: 

a. Drive is selected. 

b. Mode is set to DCPC (DMA) Channel 6 with interrupts off. 

c. Retry count is set to one. 

d. Input buffer is filled with zeros. 

These actions are not taken when OPDSN statement TEST is executed; therefore, any of them 
may be changed by the OPDSN program. If changed they will remain valid as the test is 
executed; i.e., the drive can be changed by the SD command, a different retry count may be 
selected by the RTRY command, and the interrupts may be turned on (or non-DCPC operation 
selected) by the MODE command. 



3-4. RESTARTING 

The program may be restarted by setting the P Register to 2000. Then select the desired 
program options by setting the S-Register bits according to table 3-2, and press PRESET and 
RUN. The disc I/O instructions can be reconfigured by setting the P Register to 100, setting the 
S Register according to table 3-1, and pressing PRESET and RUN. 
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Operating Procedure 

3-5. EXPECTED FREQUENCY OF ERRORS 

The normal soft error rate for a flexible disc subsystem is 1 per 100 million bits transferred 
during non-verify operations (read,write,dump), and 1 per 1 million bits transferred during 
verify operations. A standard pass without formatting (S-Register bits 0-15 set to 0) transfers 
13.9 million bits in the non-verify mode and 5.5 million bits in the verify mode. Therefore, less 
than 1 error per 7 passes is expected during standard operations and less than 5 errors per pass 
is expected during verify operations. 

Formatting of the disc transfers 5 million bits in the verify mode for each test pattern. 
Therefore, less than 5 errors per pattern is statistically predicted for Test 1. This becomes a 
statistical prediction of less than 15 errors for the three patterns. 



3-6. EXECUTION TIME 

Time to execute a pass will depend on operator intervention, error retries, message 
suppression, and sector offset. A Standard pass with no operator intervention, no errors, a 
sector offset of five, and no formatting requires approximately 20 minutes. 
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Figure 3-1. Operating Procedure Flowchart (Sheet 1 of 2) 
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Figure 3-1 . Operating Procedure Flowchart (Sheet 2 of 2) 
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Table 3-1. Initial S-Register Settings 



BITS 


FUNCTIONS 


5-0 
15-6 


Enter octal select code of control card (interface 1 ). 
Reserved 



Table 3-2. S-Register Options 



BITS 


MEANING IF CLEAR 


15-6 


Standard tests in sequence one pass, no options, and no formatting unless 0, 1 , 4, and 5 
are set. 


BITS 


MEANING IF SET 


0, 1,4, 5 

2 

3* 

6 

7 

8 

9* 

10 
11 
12 

13 
14 
15 


Enable format-altering operations (see Table 3-3). 

Alter patterns for IRAK test (see Table 5-2). 

Abort current operation and go to OPDSN input section (see paragraph 3-3). 

Spare. 

Echo console on line printer (see paragraph 3-2). 

Suppress operator intervention in TEST (CARD test) and TEST 4 (ERRR test). 

Abort current operation and go to user control section. Set A-Register bits to desired test 
numbers (see paragraph 3-3). 

Suppress non-error messages (see paragraph 2-3). 

Suppress error messages (see paragraph 2-3). 

Loop on diagnostic and suppress operator intervention in TEST (CARD test) and TEST 
4 (ERRR test). 

Loop on last test (see paragraph 3-2). 

Suppress halt on error (see paragraph 2-3). 

Halt at the end of each test (see paragraph 3-2). 


*Settlng bits 3 or 9 during a format operation may leave the disc improperly or partially formatted. 
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Table 3-3. Function of S-Register Bits 0, 1,4, and 5 



TEST 


FUNCTION FORMAT ENABLED* 


FUNCTION FORMAT NOT ENABLED 


TEST 1 & 
FALL 


Formats all of disc. 


No action. 


TEST 4 & 
ERRR 


Checks error reporting capability of disc 
including ("track not found" and "sector 
not found") and then formats all of disc. 
Disc must be previously formatted. 


Checks error reporting capability of disc 
(except "track not found" and "sector 
not found"). Disc must be previously for- 
matted. 


TEST 9 


Marks all tracks defective, then formats 
all of disc. 


Steps head from track to track 66. 


FTRK& 
FX 


Formats a single track. 


No action. 


MARK 


Marks a track defective. 


No action. 


TEST 5 & 
TRAK 


Writes worst case patterns in track-0 
sector-0, and then rewrites original con- 
tents (no. of good tracks and sector 
offset). 


Only sectors 1-29 of track are tested. 
Sectors 0-29 of other tracks are tested. 


WD & WX 


Track-0 and sector-0 may be over- 
written. 


Track-0 and sector-0 may NOT be 
ovenwritten. 


"Bits 0, 1, 4, 
listed. 


and 5 set in S-Register during execution of tf 


le OPDSN statements and standard tests 
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IV 



4-1. INTRODUCTION 

The standard diagnostic tests used in the HP 12732A Flexible Disc Subsystem diagnostic, part 
no. 12732-16003, are described in this section as well as the test options available to the 
operator. The operator selects the test options by entering S-Register bits as given in table 3-2. 
All standard tests can also be executed by calling the equivalent OPDSN subroutines as 
described in section V. There are three modes of test selection (default to standard tests, 
operator selected tests, or OPDSN) as described in paragraph 3-3. The elapsed time for each 
test and the number of bits passed in the test are given in table 4-1. 



4-2. STANDARD TESTS 

In the test descriptions below, the abbreviation "MAX" means "the maximum buffer size" 
(buffers are dynamically allocated to fill available memory), and "TR" stands for "the last good 
track." 

TEST 00 — Interface PCA's and Interrupts. Tests the ability of the interface PCA's to set 
and clear flags, and tests interrupts. Test 00 is equivalent to OPDSN subroutine CARD. 

TEST 01 — Format Entire Disc. The disc is formatted and tested for bad tracks. The number 
of good tracks is written on track 0, sector and this number is printed on the console. The 
retry count is five. Test 01 is equivalent to OPDSN program sequence. 

1 RTRY 5 
20 FALL 3 

S-Register bits 0, 1, 4 and 5 must be set to execute this test. 

TEST 02 — Read-Only Media Test. Reads entire surface of formatted disc to test for soft 
media errors with a retry count of three. If excessive errors are encountered, the disc should be 
duplicated and then reformatted with the bad tracks marked defective. Test 02 is equivalent to 
OPDSN program sequence 

1 RTRY 3 
20 RD -MAX 



Note: negative value of MAX means "all of disc" will be read. 

TEST 03 — Verify Test. Reads entire surface of formatted disc using "tight margin" flux 
transitions and the retry count is four. The equivalent OPDSN program sequence is 

1 RTRY 4 
20 VRFY -MAX 
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Note: negative value of MAX means all of disc will be read. The Verify Command is not 
normally used to read data written on another drive because the variations in alignment 
between drives may cause unusually high error rates. Therefore, Test 3 is an optional test (see 
paragraph 3-3). 

TEST 04 — Error Status Test. Tests the ability of the drive controller to recognize and report 
certain error conditions through status code reporting. The equivalent OPDSN program 
statement is ERRR. A slave drive is assumed to be present. If there is no slave, ignore the El 00 
message which is issued, and press RUN to continue. 

TEST 05 — Pattern Test. Tests the ability of the disc drive to read and write worst case 
patterns at different recording densities. In this test, three sets of patterns are written and 
verified on all sectors of tracks 0, 33, and 66 (or the last good track). The equivalent OPDSN 
program sequence is 

10 TRAK 
20 TRAK TR^2 
30 TRAK TR 

TEST 06 — Random Seek and Position. The head positioning mechanism is exercised by 
seeking random locations 256 times. No data is written or read in this test. Only preamble 
information is read. The equivalent OPDSN program statement is RAND 256 Z. 

TEST 07 — Random Seek and Write. Writes random data in random sectors of the disc and 
then reads it and compares the input and output buffers. The equivalent OPDSN statement is 
RAND 256 W. 

TEST 08 — Seek Test. Tests for correct positioning of the read/write head. The test writes 
sequential data in all sectors and tracks of the disc, verifies that the data was written 
correctly, and performs random seek and read 256 times. The equivalent OPDSN program 
sequence is 

10 WD -1 
20 VRFY -1 
30 RAND 256 R 

TEST 09 — Head Step-Mark Defective Test. The step-mark defective functions of the disc 
drive are tested. If S-Register bits 0, 1, 4, and 5 are set, the program first marks all tracks of 
the disc defective and then reformats the disc. If S-Register bits 0, 1, 4, and 5 are clear, the 
head steps from track to track 66 without altering the format of the disc. The equivalent 
OPDSN program sequence is 

10 PRST 

20 MARK 

30 GOSB 70 66 

40 FALL 3 

50 PRST 

60 STOP 

70 STEP 

80 MARK 

90 RTN 

TEST 10 — DUMP TEST. This test writes random data in random sectors of the disc. The 
data is then dumped into memory and compared to the data that was written. The equivalent 
OPDSN program sequence is 
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10 MDIS 

20 RAND 256 D 

TEST 11 — DCPC Modes Test. Reads and writes data with interrupts both off and on and 

with both of the DCPC (DMA) channels. If a significant difference in performance is achieved 
between modes, then the DCPC or interrupt hardware, or both, should be tested. The 
equivalent OPDSN program sequence is 

1 MODE D 6 
20 RAND 20 W 
30 MODE D 7 
40 RAND 20 W 
50 MODE DI 6 
60 RAND 20 M 
70 MODE DI 7 
80 RAND 20 W 

TEST 12 — Non-DCPC Modes Test. Reads and writes data with interrupts both off and on, 
without DCPC (DMA). If a significant difference in performance is achieved between modes, 
then tests should be made of the interrupt and DCPC hardware. The equivalent OPDSN 
sequence is 

1 MODE N 
20 RAND 20 W 
30 MODE NI 
40 RAND 20 W 

Frequent data overrun errors are expected in the non-DCPC mode if the diagnostic is being 
run on an HP 21 MX M-Series computer due to the diagnostic instruction execution speed. This 
does not indicate any device malfunction. For this reason. Test 12 is an optional test (see 
paragraph 3-3). 

Table 4-1. Test Execution Times and Bits Transferred 



TEST NO. 


FORMAT DISABLED* 


FORMAT ENABLED** 


BITS TRANSFERRED 


VERIFY 


NON-VERIFY 




1 

2 

3t 

4 

5 

6 

7 

8 

9 
10 
11 
12t 


min., 1 sec. 

min., sec. 

1 min., sec. 
1 min., sec. 
min., 2 sec. 

min., 20 sec. 

1 min., 10 sec. 
5 min., 15 sec. 
4 min., 40 sec. 

min., 5 sec. 
4 min., 40 sec. 

1 min., 40 sec. 
min., 50 sec. 


same 
8 min. 
same 
same 
8 min. 
25 sec. 
same 
same 
same 
8 min. 
same 
same 
same 


None 
15M** 

4.8M 
15M" 
0.7M 

4.8Mt 
15M** 


None 
4.8M 

0.4M 
3.3M 
3.0Mt 

1.4M 
1.0M 
0.5M 


* S-Register bits 0, 1 , 4, and 5 clear. 
** S-Register bits 0, 1,4, and 5 set (format enabled), 
t Optional tests. 
t 7.8M bits total. 
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OPERATOR DESIGN SECTION 



SECTION 



5-1. INTRODUCTION 

The Operator Design Section (OPDSN) is entered by setting S-Register bit 3. OPDSN gives the 
operator access to all tests from through 12 as well as several utility routines. The tests are 
defined as a series of calls to the OPDSN routines. The purpose of OPDSN is to allow the 
operator to design the diagnostic test which will be most useful in solving a current problem. 

Many of the OPDSN subroutines facilitate use of the oscilloscope to observe the behavior of the 
subsystem at a component level. Further simplification of testing may be possible by using 
specially written routines to analyze a particular operation. To assist in writing such routines, 
a minimal disc control routine program is provided in Appendix E as an example. The OPDSN 
statements and utility commands are summarized in table 5-1. 



5-2. PROGRAMMING LANGUAGE 

OPDSN uses a programming language similar to BASIC. All program statements begin with a 
line number which is used for sequencing. The statements include a mnemonic statement of 
two to four characters and two parameters. The parameters may be in ASCII, an integer, or an 
octal number depending on the statement. 



5-3. PARSING NOTES AND LABELING 

The following parsing notes are for OPDSN programming in its BASIC like language: 

a. Input blocks are separated by any number of spaces, or a single comma. 

b. Parameters not given will default to zero (except as noted in the description of OPDSN 
program statements below). 

c. Checking is done for correct parameter type (ASCII, integer, octal) and value. 

d. Statements may be entered in any order. They will be sorted automatically by line 
number. (Line numbers must be in the range from 1 to 9999.) 

e. Each line of input is terminated by a carriage-return/line-feed (CR-LF). 

f. A line may be deleted prior to the CR-LF by striking RUBOUT or DELETE. 

g. After a statement has been entered, it may be deleted by typing the line number, then 
CR-LF, or it may be replaced by a new statement with the same number. 

h. ASCII parameters may contain only letters (A-Z), digits (0-9), and hyphens (-). 

i. Integer parameters must be in the range from -32768 to 32767. 
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j. Octal parameters must be in the range from to 111111. 

The following labeling conventions are used: 

a. A equals an ASCII parameter, 2 characters, the first is not a space. 

b. S equals an ASCII parameter, 2 characters, the first is not a space. 

c. / equals an Integer parameter, positive or negative. 
d- N equals an Integer parameter, positive or negative. 

e. K equals an Octal parameter. 

f. B equals an Octal parameter. 

5-4. OPDSN PROGRAM 

OPDSN commands provide the same functions which are used in the standard test programs. 
The user can employ most of the OPDSN commands for immediate execution by omitting the 
program line number, or as a program statement by including a program line number. 
However, some commands can only be used one way or the other. For example, "GO" is an 
immediate command only, and "STOP" can only be used as a program statement with a line 
number. OPDSN commands described below are for both program statements and immediate 
execution unless otherwise noted. When entering an OPDSN program, be sure to comply with 
the parsing and labeling conventions given in paragraph 5-3. 

Error conditions cause messages and status reports to be output to console. All error conditions 
that can be forced programmatically are tested with the ERRR statement. Status words and 
masks, and operation command codes are listed in Appendix A. Error messages are listed in 
Appendix B. The OPDSN program statements and commands are described below. (Refer to 
paragraph 5-5 for Special OPDSN statements.) TO USE A MNEMONIC AS A PROGRAM 
STATEMENT, IT MUST BE PRECEDED BY A LINE NUMBER. Unnumbered mnemonics 
are executed immediately upon CR-LF. 

CARD. Tests the computer's interrupt system and both interface cards, first the control 
channel and then the data channel (equivalent to TEST 0)*. The tests on both cards are 
identical evoking error messages EOOO through E023 and E026, and information messages 
H024 and 1025. 

There are eight tests as follows: 

a. Subtest 1 checks the ability to clear, set and test the interrupt system, using the following 
instruction combinations: 

CLF SFC 
CLF SFS 
STF SFC 
STF SFS 

Errors in these instruction checks produce error messages EOOO through E003. 

*If more thorough testing of the interface cards is desired, use the General-Purpose Register 
Diagnostic as described in paragraph 2-4 of this manual. 
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(CARD Continued) 



b. Subtest 2 checks the ability to clear, set and test the interface flag using the following 
instruction combinations: 

CLF SC SFC SC 
CLF SC SFS SC 
STF SC SFC SC 
STF SC SFS SC 

Errors in these interface flag checks produce error messages E005 through EOlO. SC is 
the Select Code for the disc drive interface being tested. 

c. Subtest 3 checks that the test select code does not cause an interrupt with the flag and 
control set on the interface and the interrupt system off, using the following sequence: 

STF SC 
STC SC 
STF 
CLF 

The CLF instruction should inhibit an interrupt from occurring due to the interface. 
Error message E004 occurs if CLF fails in this. 



d. Subtest 4 checks that the flag of the interface-under -test is not set when all other select 
code flags are set. Error message EOll occurs if a flag is set incorrectly. 

e. Subtest 5 checks the ability of the interface to interrupt with the flag and control set and 
the interrupt system on. If the interrupt is missing E014 occurs. It also checks that the 
interrupt occurs when expected and not ahead of the execution of instructions which affect 
priority. This hold-off operation is tested by the following sequence: 

STC 1 
STF 1 
CLC 1 
CLF 1 

JMP # + 1 ,1 
DEF »+1 
JSB *+1 , I 
DEF »+1 
NOP 

Error messages E012 and/or E015 will occur if the hold-off failed. If a second interrupt is 
encountered after the first interrupt has been satisfied, an error message E013 will occur. 
This test also checks whether or not an instruction was missed during the interrupt, giving 
the message E026 INT EXECUTION ERROR in the event of an error. 



Subtest 6 checks for no interrupt following a CLC SC instruction when the interrupt 
system is on, and the SC control and flag are set. The following sequence of instructions is 
used: 
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(CARD Continued) 

STC SC 
STF SC 
STF 
CLC SC 

If the CLC SC fails to inhibit an interrupt, error message E016 will occur. 

g. Subtest 7 checks that the CLC instruction inhibits interrupts when the SC control and 
flag are set. This is provided by the following set of instructions: 

CLF SC 
STC SC 
STF SC 
STF 
CLC 

If the CLC fails to inhibit an interrupt, error message E017 will occur, 
h. Subtest 8 checks that the PRESET switch on the operator panel performs as follows: 

Sets the interface flag 
Clears the interface control 
Turns off the interrupt system 
Clears the I/O data lines 

Error messages E020 through E023 may occur if any of these conditions are not achieved. 

CB I N. Compare first I words of input and output buffers. I defaults to the size of the last data 
transfer. N equals maximum number of errors printed (defaults to 8) and remains valid for the 
subsequent commands RD C, VRFY C, and DUMP C, until the program is restarted from 
address 2000. Errors are listed on the console. 

CBP I N. Same as CB I N except that errors are listed on the line printer. 

DB. Fill the output buffer with random data. (FALL, TRAK, WD -1, RD -1, VRFY -1, RAND, 
and DBFK also modify the output buffer.) 

DBFK K B. Fill the output buffer with an alternating octal pattern. K is stored in odd 
numbered words and B is stored in even numbered words of the buffer. (FALL, TRAK, WD -1, 
RD -1, VRFY -1, RAND, and DB also modify the output buffer.) 

DBRK I N (Without Line Number). Replace words I to N of the output buffer with data from 
the console (I may not be zero). Operator enters values, any number per line, separated by 
spaces or commas. If too many values are input, the buffer size is output to the console. The 
input is terminated by a non-octal value. 

DBSZ. Print the output buffer size. 

DUMP A. A special data-recovery read operation which retrieves data from a sector whose 
format information has been destroyed. The drive seeks to the sector ahead of the current 
sector on the same track. Data is transferred from the current sector in blocks of 128 words. 
Setting parameter A to C will compare input and output buffers following transfer. 
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DLY I. Pause I milliseconds. 

EP (Without Line Number). Erase Program. 

ERRR. Test for error status including all error conditions that can be forced (equivalent to 
TEST 04). No error messages are output unless the appropriate error status is not achieved. 
Error status codes are listed in Appendix A. 

a. If operator intervention is suppressed by S-Register bit 8 or bit 12, skip to step h. 

b. "TURN OFF MASTER" message output with halt. Operator should turn off controller 
power and press RUN (PSTS line should go low). "RESTORE POWER" message output 
with halt. Operator should restore controller power and press RUN. 

c. "TURN OFF SLAVE" message output with halt. Operator should turn off power of a slave 
drive if one is available, but ignore message if not available. (Status for "No Drive Power" 
is expected.) Press RUN. "RESTORE POWER" message output with halt. Operator should 
restore slave drive power and press RUN. 

d. "OPEN DOOR" message output with halt. Operator should open drive door and press 
RUN. (Expected status is "drive door open" and "disc change".) 

e. "REMOVE DISC, CLOSE DOOR" message output with halt. Operator should remove the 
disc, close the drive door, and press RUN. (Expected status is "no disc in drive" and "disc 
change".) 

f. "INSERT PROTECTED DISC" message output with halt. Operator should place a write 
protected disc in the drive, close the door, and press RUN. (Expected status is "protected 
disc" and "disc change".) 

g. "INSERT UNPROTECTED DISC" message output with halt. Operator should place a 
non-protected disc in drive and press RUN. (Expected status is "disc change".) 

h. Output the following illegal commands (command codes are in octal): 
100000 Write zero sectors 
040000 Verify zero sectors 
144640 Seek track 77 sector 

147775 Seek track 127 sector 29 
140037 Undefined command 
147577 Undefined command 

i. Output the below illegal commands if S-Register bits 0,1,4, and 5 are set: 
144676 Format track 77 

147776 Format track 127 

j. Cause data overrun by not raising CTLO on a partial sector read and write. 

k. Exit if S-Register bits 0,1,4, and 5 are not set. Mark track 2 defective. Read zero sectors at 
track 2 on sectors 0,15, and 29 (expected status is "track not found"). Next read zero sectors 
at track 1 sector 29 and at track 3 sector (expected status is "seek complete"). 

1. Format track 3, numbering all sectors 29. Read zero sectors at track 3 sectors 1, 15, and 29 
(expected status is "sector not found"). Then read zero sectors at track 3 sector (expected 
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(ERRR Continued) 

status is "seek complete"). (The "read zero sectors" command reports sector found when the 
previous sector on the same track is found.) 

m. Re-format the entire flexible disc (equivalent to FALL 3). 

EX. Exit OPDSN. Return to standard test execution. 

FALL I N. Format entire disc where I equals the number of patterns for track test (see TRAK 
test and table 5-2), and N equals the sector offset (defaults to 5). S-Register bits 0,1,4, and 5 
must be set to enable command. Before execution, the message "FORMAT" is output to 
console. After successful completion, the message "GOOD TRACKS = #" is output to console. 
Operation of the test formats each track, then tests it for good format and media as under the 
TRAK test. The track is marked defective upon the occurrence of one of the following errors 
which has not been corrected within the retry count: 

a. Sector not found (status E=0101). 

b. Track not found (status E= 0110). 
Data checkword error (status E=0111). 

d. Data overrun (status E= 1000). 

e. Verify error (status E= 1001). 

After testing the last track, the number of good tracks is written in the first word of track 0, 
sector and printed on the console and the sector offset is written in the second word of the 
sector. Track 0, sector can not be altered by any other command unless S-Register bits 0,1,4, 
and 5 are set. (An attempt to write in sector causes message "E044 TR SEC 0".) 

A File Manager (FMGR) directory is written on the last good track. 

FTRK I N. Format a single track where I is the track number and N is the sector offset 
(defaults to 5). The track number I will be written on the format portion of the track. No head 
movement results from this command. 

GrO (Without Line Number). Execute user program. 

GOSB I N (With Line Number). Jump to subroutine (a block of statements beginning at line 
I and terminating at the statement RTN). Repeat subroutine N times (N defaults to 1). 

GOTO I (With Line Number). Jump to line I where I is from 1 to 9999. 
LI I N. List the input buffer from words I to N (I may not be zero). 

LIP I N. List input buffer on line printer from words I to N (I may not be zero). 
LO I N.List the output buffer from words I to N (I may not be zero). 
LOP I N. List the output buffer on line printer from words I to N (I may not be zero). 
LP (Without Line Number). List the user OPDSN program. 
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LPP (Without Line Number). List the user OPDSN program on the line printer. 

MARK K B. Mark current track defective, without head motion. Precede this statement in a 
program with PRST and STEP statements to position the head at the defective track. If 
already positioned at the track, it may be used as an immediately executable command. K 
equals expected status (default=0), and B equals status mask (default= 177773). Be sure to 
follow this statement with a PRST statement or command before proceeding with any data 
transfer operations. 

MDIS L Mount disc. I equals the number of good tracks. This command informs the diagnostic 
of the number of good tracks, and the sector offset of the flexible disc being tested. It should be 
executed each time a new disc is placed in the drive. If I equals 0, the number of good tracks 
and the sector offset are read from track 0, sector 0. 



MODE A I. Set mode of I/O operations on disc where A equals ASCII character(s) and I equals 
DCPC(DMA) channel number (6 or 7). The characters for A are below: 

DI=DCPC, interrupts on 
D =DCPC, interrupts off 
NI=noDCPC, interrupts on 
N =no DCPC, interrupts off. 

The DCPC instructions are initially configured to Channel 6. If no channel number is 
specified, the previous channel configuration is retained. If parameter A is not specified, 
MODE defaults to DCPC without interrupts. If DCPC is not available, DCPC requests will be 
automatically converted to equivalent non-DMA requests and the message "NO DMA" will be 
output to the console. 

MOVE I. Seek I sectors forward or backward where I can be positive or negative. The seek 
command is not output to the disc controller and no head movement occurs until the next data 
transfer command (WRITE,READ,VERIFY, or DUMP). For example, if current location is 
track 10, sector 14, a statement MOVE 12 is equivalent to SK 10 26; and MOVE -3 is 
equivalent to SK 10 11. To make the current location the same as the starting location of the 
previous data transfer, omit I. 

MSG A S. Output message to console where A and S are two ASCII characters each. For 
example, MSG TE XT appears as "*TEXT". 

PRST. Preset controller and physically position the master and all slave drives to track 0, 
sector 0. Use this command after a STEP or MARK command before proceeding with data 
transfer statements. The disc change bit will be set in the next status word returned by the 
controller. 

RAND I A. Random seek for read and write where I equals the iteration count which must be 
greater than zero. Set parameter A as follows: 

S = generate random track and sector number and send to controller (no head motion 
expected). 

Z = same as S followed by "read zero words" to physically position the head. 
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(RAND Continued) 

R = same as S followed by read random length block of data (1 to octal 2000 words), fill 
the output buffer with sequential data, and compare buffers. Refer to statement 
"WD" for a definition of sequential data. NOTE: RAND with this parameter must 
follow a "WD -1" command. 

W= same as S followed by filling output buffer with random data, then writing a 
random length block of data of 1 to 2000 (octal) words, and reading the data that 
was written into the input buffer. Next the output and input buffers are compared. 

D = same as S followed by writing 128 words of random data, dumping the data, and 
then comparing the input and output buffers. 

RD I A. Read I words from the disc into the input buffer. If I equals zero, the head will 
physically position to the sector preceding the current location with no data transfer. I may not 
exceed the input buffer size. The following occurs if I is a negative number: 

a. The number of good tracks is read from track 0, sector (equivalent to MDIS). 

b. The entire disc is read into the input buffer, I words at a time where I is an absolute value 
(minus sign ignored). 

c. Where I equals (— 1), the output buffer is filled with sequential data prior to each read 
operation. Refer to statement WD (I- 1) for a definition of sequential data. Setting the 
parameter A to C will compare input and output buffers after each read operation. 

For example, the following program writes data on the disc from the output buffer, reads it into 
the input buffer, and checks for correct transfer: 

1 WD 384 
20 MOVE 
30 RD 384 C 

RTN (With Line Number). Return from subroutine. Continue execution at line following last 
executed GOSB when the last programmed GOSB repeated sequence is completed. 

RTRY I. Retry any subsequent commands when the expected status is not achieved or if the 
disc drive times out. The retry count is checked after each try until the count exceeds I or the 
correct status is returned. An uncorrectable error will be retried 1+ 1 times and 1+ 1 error 
messages are expected. A soft error results in fewer error messages. I must be between and 
15. 

SD I. Select drive I. All subsequent commands vi^ill access drive I where I is from to 3. 

SK I N. Seek track I, sector N. The seek command is not output to the disc controller and no 
head movement occurs until the next data transfer command (WRITE, READ, VERIFY, or 
DUMP). 

ST K B. Status request command issued to the disc controller where K is the expected status 
and B is a mask for the returned status (refer to table A-2). The returned status is masked 
(logical AND) with B and compared to K expected status and is not printed unless the results 
are unequal. K defaults to 000000 (controller power on and no errors) and B defaults to 177777. 
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STAT. Print last status, expected status, operation, track and sector, and mode. This is the 
only command for printing non-error status. 

STEP K B. Physically steps head inward, one track at a time. (Seek or data transfer 
commands automatically step the head.) STEP and PRST are the only two commands which 
will position the head on an unformatted disc. K is the expected status (defaults to octal 40) 
and B is the status mask (defaults to octal 177763). Follow this statement with a PRST 
statement before proceeding with data transfer commands. 

STOP (With Line Number). Stop execution of OPDSN program and return to OPDSN input 
after message. The message output to the console is "STOP (LINE XXXX)". 

TEST L Execute standard test L Refer to section IV for a description of the tests and to 
paragraph 3-3 for alternate modes of test selection. 

TRAK I N. Track I is tested by writing and verifying N pattern-pairs in all sectors. Refer to 
table 5-2 for the worst case bit patterns used and the methods of alteration. N may be from 1 
through 7 (defaults to first 3 pattern pairs of table 5-2). 



NOTE 

If track is selected, two conditions are possible depending on 
whether S-Register bits 0, 1,4, and 5 are set or not set. If these 
bits are set, then all sectors are tested and the number of good 
tracks are rewritten in sector 0. If these bits are no't set, then 
only sectors 1 through 29 are tested, skipping sector 0. 

VRFY I A. Read with "tight margin" on flux transitions. "Tight margin" shortens the time 
allowed for a read such that a flux transition on the disc track has a narrower window than 
normal in which to be sensed by the read/write head. The parameters are exactly the same as 
for RD except that I is not allowed to be zero. The data is transferred to the input buffer. 

WAIT (With Line Number). Output message "WAIT (LINE XXXX)" to console. Operator 
responds with "ST" to stop execution of the user program, or "CO I" to continue at line number 
I. "CO" without line number XXXX will cause the next line to be executed. 

WD I. Write I words from output buffer to the disc (I = is illegal). I must not exceed the 
output buffer size. If I is specified as a negative number, the following occurs: 

a. The number of good tracks is read from track 0, sector (equivalent to MDIS). 

b. The entire disc is written with data from the output buffer, I words at a time where I is an 
absolute value (minus sign ignored). 

c. For I = — 1 the output buffer is filled with "sequential data" prior to each write operation. 
"Sequential data" is defined as an alternating pattern with the odd numbered locations 
containing the number of the sector to be written in bits 5-0 and the track to be written in 
bits 15-6, and the even numbered locations containing the complement of that number. For 
example, track 0, sector 15 is filled with octal numbers 000017,177760, 000017, 177760, 
etc.; and track 6, sector 1 is filled with octal numbers 000601, 177176, 000601, 177176, etc. 
The number of good tracks is read from track 0, sector and the entire disc is written with 
the patterns. 
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NOTE 

Track 0, sector may be altered only if S-Register bits 0, 1, 4, 
and 5 are set. 



5-5. SPECIAL OPDSN STATEMENTS 

The special OPDSN statements are not used in any of the standard diagnostic tests. They are 
used in OPDSN programming to give the operator access to the basic disc drive commands 
without the error checking and command combinations which are typical of the other OPDSN 
statements. The special OPDSN statements are of value for component repair and error status 
checking. 

These statements comply with the parsing and labeling conventions of paragraph 5-3; 
however, care should be taken when mixing these special statements and the other OPDSN 
statements due to the following differences: 

a. SX command outputs a seek to the drive controller, but SK and MOVE commands do not. 

b. WX, RX, VX, and DX do not output a seek to the drive controller, but WD, RD, VRFY, and 
DUMP do provide a seek. 

c. WX, RX, and VX do not truncate requests that will overflow the last good track of the disc. 

d. WX, VX, SX, FX, and UX allow an illegal command, or invalid track and sector, to be 
output. 

e. Errors will not cause an automatic retry. 

f. The status mask is 177777 except as noted below in the command description. 

The special OPDSN statements must be preceded by a line number for programming but they 
may also be used without line numbers as commands for immediate execution. Refer to table 
A-2 to determine the default expected status and mask. 

DX K B. Dump 128 words from the disc to input buffer where K is the expected status and B is 
the status mask (default = 177763). This command should be preceded by a seek to the sector 
physically preceding the desired sector, and by a read-zero sectors (RX 0) command for head 
positioning. 
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FX I K. Format a single track without head movement. In formatting, track I is written in the 
preamble of each sector and the first 30 words of the output buffer are written as sector 
addresses. When a sector address of over 29 is passed to the drive controller, an illegal 
command status is returned. Set S-Register bits 0, 1, 4, and 5 to enable this command. I must 
be from to 127 (decimal). K is the expected status. 

RX I K. Read I words from the disc to the input buffer where I may not exceed the input buffer 
size. If I is negative, control line CTLO will be output to the disc controller (this indicates a 
partial sector). I may be zero and K equals the expected status. 

SX I K. Output a seek command to the disc controller where I = [(track x 100) + sector]. The 
track number must be from to 127 and the sector number must be from to 29. K equals the 
expected status which is only returned for an illegal track number. 

UX I K. Output an undefined command to the disc controller. The undefined command is the 
octal pattern 140037 with I added to bits 11-5 (the track field of the seek command) and the 
drive number added to bits 13-12. I must be between and 123. K equals the expected status. 

VX I K. Verify I words from the disc to the input buffer where I may not exceed the input 
buffer size. If I is negative, control line CTLO will be output to the disc controller (this indicates 
a partial sector). I may be zero and K equals the expected status. 

WX I K. Write I words from the output buffer to the disc where I may not exceed the output 
buffer size. If I is negative, control line CTLO will be output to the disc controller (this indicates 
a partial sector). I may be zero and K equals the expected status. 



Table 5-1. Summary of OPDSN Commands 



COMMAND* 


FUNCTION 


CARD 


Test interface cards and Interrupts. 




CB 1 N 


Compare buffers (1 = words, N = maximum errors). 




CBP 1 N 


Compare buffers, output errors on line printer (1 = words, N = maximum errors). | 


DB 


Fill output buffer witfi random data. 




DBFK K B 


Fill output buffer withi octal alternating pattern. (K = odd word pattern, B = 
word pattern). 


even 


DBRK 1 N** 


Replace words 1 to N with octal data from console. 




DBSZ 


Print output buffer size. 




DUMP A 


Dump 128 words and compare buffers. (A = C to compare). 




DLY 1 


Delay 1 milliseconds. 




DX K B 


Dump (K = expected status, B = mask). 




ERRR 


Force error status. 




EP** 


Erase program. 




EX 


Exit OPDSN. 




FALL 1 N 


Format entire disc (1 = number of patterns, N = sector offset). 




FTRK 1 N 


Format track 1 (N = sector offset). 




FX 1 K 


Format track 1 (K = expected status). 




GO" 


Execute user program. 




GOTO If 


Jump to line 1. 




GOSB 1 Nf 


Repeat subroutine starting at line 1, N times. 




LI 1 N 


List input buffer from word 1 to word N. 




LIP 1 N 


List input buffer from word 1 to N on line printer. 
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Table 5-1. Summary of OPDSN Commands (Continued) 



COMMAND* 


FUNCTION 


LO 1 N 


List output buffer from word 1 to N. 


LOP 1 N 


List output buffer from word 1 to N on line printer. 


LP" 


List user program. 


LPP** 


List user program on line printer. 


MARK K B 


Mark track defective (K = expected status, B = mask). 


MDIS 1 


Mount disc (1 = number of good tracks). 


MODE A 1 


Set mode of I/O AND DCPC (A = mode, 1 = DCPC channel). 


MOVE 1 


Seek 1 sectors forward or backward. 


MSG A S 


Output four character ASCII message to console. 


PRST 


Preset controller and seek home. 


RAND 1 A 


1 = iteration count. A = S, Z, R, W, or D for random seeks, 




writes, reads, or dumps. 


RD 1 A 


Read 1 words and compare buffers (A = C to compare). 


RTNt 


Return from subroutine. 


RTRY 1 


Set up retry count. 


RX 1 K 


Read 1 words (K = expected status). 


SD 1 


Set up drive number (0 to 3). 


SK 1 N 


Seek track 1, sector N. 


ST K B 


Request status (K = expected status, B = mask). 


SX 1 K 


Seek (1 = [track x 1 00] + sector, K = expected status). 


STAT 


Print last status. 


STEP K B 


Step head in one track (K = expected status, B = mask). 


STOPt 


Stop execution of OPDSN program. 


TEST 1 


Execute standard diagnostic test 1. 


UX 1 K 


Undefined command (1 = "track", K = expected status). 


TRAK 1 N 


Pattern test of track 1 (N = number of patterns). 


VRFY 1 A 


Verify 1 words and compare buffers. 


VX 1 K 


Verify 1 words (K = expected status). 


WAITt 


Wait for operator (operator enters ST or CO 1). 


WD 1 


Write 1 words (Negative 1 = write entire disc). 


WX 1 K 


Write 1 words (K = expected status). 


* Command use requires line number for program statements and no line number for immediate 


execution upon CR-LF. Some commands can be used in only one of the two modes as footnoted 


(** = without line number, f = with line number). 


" Use without line number for immediate execution. 


t Use with line number in program statements. 
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Operator Design Section 



Table 5-2. Worst Case Test Pattern Pairs for TRAK and FALL 



WORST CASE PATTERN PAIRS 


PAIR 


A REG. 


B REG. 


1 
1 
3 
4 
5 
6 
7 


033066 
125252 
106615 
155555 
133333 
143306 
RANDOM 


033066 
052525 
106615 
155555 
133333 
143306 
RANDOM 


Note: To alter or display the patterns, set S-Register bit 2. Computer will halt 
1 06002 with the first pattern pair in the A and B registers. Altering A and 
B will cause the pattern table to be altered. Press RUN to display the 
next pattern 
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Table A-1. Status Words 















BIT NO. 


15 


14 13 12 


11 10 9 


8 7 6 


5 4 3 


2 1 




CODE 


P 





E E E 


EOT 


S R W 


C D 










BIT 


CODE 


MEANING 


DATA (OCTAL) 





D 


Drive Number 


000000 to 


1 







000003 


2 


C 


Change bit. PRST executed or power restored, or 
door is open, or door was opened since last status 
return. 


000004 


3 


w 


Write Protected Disc 


000010 


4 


R 


Drive Not Ready (no drive power, door open, no 
disc in drive) 


000020 


5 


S 


Seek or Step Complete 


000040 


6 


T 


Transfer Complete (read, write, verify, dump, 
format) 


000100 


7 





Not Used 








E 


No Error 


000000 






E 


No Drive Power 


000400 






E 


Drive Door Open 


001000 


8 




E 


No Disc in Drive 


001400 


9 




E 


Invalid Command 


002000 


10 




E 


Sector Not Found 


002400 


11 




E 


Track Not Found 


003000 






E 


Data Checkword Error 


003400 






E 


Data Overrun 


004000 






E 


Verify Error 


004400 


12 





Not Used 




13 





Not Used 




14 





Not Used 




15 


p 


Controller Power Off or Current Operation Not 
Successful 


100000 


Notes: All disc controller commands, except seek, return status in bits 15-0 of the data channel. Status 


P, shown in bit 15, is signal PSTS (bit 15 of control channel) logically inverted. 
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status, Masks, and Command Codes 



Table A-2. Expected Status for Standard Tests 


DEFAULT 






EXPECTED 






STATUS" 


MASK* 


CONTROLLER OPERATION 


000000 


177763 


Status Request — no errors 


000100 


177773 


Format 


000040 


177763 


Step, Seek 


000000 


177773 


Mark 


000140 


177773 


Write 


000140 


177763 


Read, Verify 


000100 


177763 


Dump 


102000 


177763 


Illegal Command 


004040 


177763 


Data Overrun on Read or Write 


103000 


177763 


Track Not Found on Read 


102400 


177763 


Sector Not Found on Read 


100420 


177763 


No Drive Power (Status Request) 


001024 


177777 


Drive Door Open (Status Request) 


001424 


177777 


No Disc in Drive (Status Request) 


000014 


177777 


Protected Disc (Status Request) 


000004 


177777 


Disc Change (Status Request) 


* Bit patterns which are programmed in commands to eliminate unwanted status bits. 


Mask 1 77763 eliminates the C (change) bit and the W (Write protect) bit. 


** Add drive number to the listed expected status. 



Table A-3. Disc Command Operation Codes 



COMMAND 


OP CODE 


AUGMENTED CODE AND LIMITATIONS 


READ 
WRITE 
VERIFY 

SEEK 

FORMAT 
STEP 
MARK 
DUMP 

STATUS 


OOXXXX 
10XXXX 
04XXXX 
14XXXX 

14XX36 
147637 
147677 
147737 
147777 


XXXX = No. of Sectors (bits 11-0) from 0-4406 (octal) 

XXXX = No. of Sectors (bits 1 1 -0) from 0-4406 (octal) 

XXXX = No. of Sectors (bits 1 1 -0) from 0-4406 (octal) 

XX (bits 11-5) = Tracks from 0-114 (octal) 

XX (bits 4-0) = Sectors from 0-35 (octal) 

XX plus bit 5 (bits 11-5) = Tracks from 0-114 (octal) 


Notes: 

1. The drive number is added to the above command codes in bits 13-12. 

2. All commands except seek cause an automatic status return at completion of the operation. 

3. The controller has two internal states, a command acceptance state, and an execution 
state. Presetting the controller (PRST) puts it in the command acceptance state. (A pulse on 
bit of the control channel presets the controller.) Before any command will be recognized, 
the controller "password" (127207B) must be output to the data channel. The command is 
then output to the data channel, followed by the required data. The data channel flag will be 
set by the controller after every word of data. Most error conditions will cause the control 
channel flag to set and the automatic status to be returned. 

4. Data transmission may be terminated after a partial sector by setting bit 1 of the control 
channel (CTLO) after the last word of data has been transferred. The automatic status is 
then returned by the controller. 
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B 





Table B-1. Error and Information 


Messages and Halt Codes 


MESSAGE 


HALT 
CODE 


PROGRAM 
SECTION 


COMMENTS 


CODE 


TEXT 




HP 12732 

FLEXIBLE DISC 

DIAGNOSTIC 


None 


Test Control 


Introductory Message 




TEST XX 


None 


Test Control 


XX-Test Number. Occurs before execution of 
each test. 


EOOO 


CLF 0— SFC 


102000 


Test 


CLF/SFC combination failed. CLF did not 
clear flag or SFC caused no skip with flag clear. 


E001 


CLF 0— SFS 


102001 


Test 


CLF/SFS combination failed. CLF did not 
clear flag or SFS caused skip with flag clear. 


E002 


STF 0— SFC 


102002 


Test 


STF/SFC combination failed. STF did not set 
flag or SFC caused skip with flag set. 


E003 


STF 0— SFS 


102003 


Test 


STF/SFS combination failed STF did not set 
flag or SFS caused no skip with flag set. 


E004 


CLF DID NOT IN- 
HIBIT INT 


102004 


Test 


With card flag and control set, CLF did not 
turn off interrupt system. 


E005 


CLF CH— SFC CH 


102005 


Test 


CLF/SFC CH (Select Code) combination failed. 
CLF did not clear flag or SFC caused no skip 
with flag clear. 


E006 


CLF CH— SFS CH 


102006 


Test 


CLF/SFS CH (Select Code) combination failed. 
CLF did not clear flag or SFS caused skip with 
flag clear. 


E007 


STF CH— SFC CH 


102007 


Test 


STF/SFC CH (Select Code) combination failed. 
STF did not set flag or SFC caused skip with 
flag set. 


E010 


STF CH— SFS CH 


102010 


Test 


STF/SFS CH (Select Code) combination failed. 
STF did not set flag or SFS caused no skip with 
flag set. 


E011 


STF XX SET CARD 
FLAG 


102011 


Test 


Select code screen test failed. A-Register 
contains XX (octal) where XX equals select 
code that caused card flag to set. 


E012 


INTDURINGHOLD 
OFF INSTR 


102012 


Test 


Interrupt occurred during an I/O instruction or a 
JMP/JSB indirect instruction. 


E013 


SECOND INT 


102013 


Test 


Card interrupted a second time after initial 
interrupt was processed. 


E014 


NO INT 


102014 


Test 


No interrupt occurred with card flag and control 
set and the interrupt system on. 



B-1 



Messages and Halt Codes 



Table B-1. Error and Information Messages and Halt Codes (Continued) 



MESSAGE 


HALT 
CODE 


PROGRAM 
SECTION 


COMMENTS 


CODE 


TEXT 


E015 


INT RTN ADDR 


102015 


Test 


Interrupt did not occur at the correct location 
in memory. 


E016 


CLC CH 


102016 


Test 


CLC CH (Select Code) did not clear card control 
with the interrupt system on. 


E017 


CLC 


102017 


Test 


CLC did not clear the card control with the 
interrupt system on. 


E020 


PRESET DID NOT 
SET FLAG 


102020 


Test 


PRESET did not set the card flag. 


E021 


PRESET DID NOT 
DISABLE INTS 


102021 


Test 


PRESET did not disable the interrupt system. 


E022 


PRESET DID NOT 
CLEAR CONTROL 


102022 


Test 


PRESET did not clear control. 


E023 


PRESET DID NOT 
CLEAR I/O LINES 


102023 


Test 


PRESET did not clear I/O data lines. 


H024 


PRESS PRESET, 
RUN 


102024 


Test 


Press PRESET, then RUN. (Occurs twice in 
test 0, once for each select code.) 


1025 


CARD (SC = XX) 


None 


Test 


Precedes card test error message. XX = 
Select Code of interface card. 


E026 


INT EXECUTION 


102026 


Test 


Interrupt was not processed correctly. 


H030 


OPDSN 


None 


OPDSN 


Indicates that OPDSN section has been entered. 
@ is prompt character for input. 


1031 


STOP (LINE XXXX) 


None 


STOP 


OPDSN statement "STOP" at line XXXX has 
been executed. 


1032 


INPUT ERROR 


None 


OPDSN 


Undefined statement or Invalid parameter has 

been entered. 


1033 


FULL 


None 


OPDSN 


User program area full. 


1034 


LINE? (LINE XXXX) 


None 


GOTO 

GOSB 

WAIT 

RTN 


Statement at line XXXX references an unde- 
fined line, or "RTN" statement executed with- 
out matching "GOSB" statement. 


1035 


GOSB (LINE XXXX) 


None 


GOSB 


Nesting of "GOSB" calls has exceeded 16 
levels. Return pointer stack overflow. 


H036 


CNT = XXXXX 


None 


DBSZ 


Size of output buffer in words. 


1040 


WAIT (LINE XXXX) 


None 


WAIT 


"WAIT" statement at line XXXX has been 
executed. Enter "ST" to stop execution of user 
program or "CO N" to continue execution at 
line N (next line if N omitted). 
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Messages and Halt Codes 
Table B-1. Error and Information Messages and Halt Codes (Continued) 



MESSAGE 


HALT 
CODE 


PROGRAM 
SECTION 


COMMENTS 


CODE 


TEXT 


H041 


RAND R 


None 


RAND 


Sequential data expected by RAND nnnR not 
achieved. (WD -1 must precede this state- 
ment.) Seek mechanism failure. See RAND 
and WD, Section 5. 


1042 


FORMAT 


None 


FALL 


Indicates start of FALL command. 


H043 


GOOD TRACKS: 
XX 


None 


FALUMDIS 


Indicates number of usable tracks on this disc 
(written on track 0, sector 0). 


E044 


TR SEC 


102044 


WD 


An attempt was made to alter track 0, sector 
(number of good tracks). S-Register bits 0, 1 , 4, 
and 5 must be set, or the user program must 
be altered. 


1044 


TR SEC 


None 


WD, TRAK 


Track 0, sector (number of good tracks) 
has been altered. 


H045 


END OF DISC 


None 


WD, RD 
VRFY, 
DUMP 


An attempt was made to transfer data past the 
last good track of the disc (or to a negative 
numbered track, set up by MOVE-N). All avail- 
able sectors will be used by a multiple-sector 
command. 


H046 


WORD NO. 
OUTPUT INPUT 


None 


RD, VRFY 
DUMP, CB 


Heading for message E047. Comparison of 
input and output buffers failed. 


E047 


XXXXX 
YYYYYY 
ZZZZZZ 


None 


RD, VRFY, 
DUMP, CB 


Comparison of input and output buffers failed. 
First number is the decimal position of the pair 
of values. Second number is the value of the 
output buffer (octal). Third number is the value 
of the input buffer (octal). 


E050 


TLOG = XXXXXX 
EXP = YYYYYY 


102050 


All data 

transfer 

commands 


Incomplete data transfer operation. XXXXXX = 
log (number of words transferred). YYYYYY = 
expected log (number of words expected). 


E051 


*T0* 
DMA, CC 


102051 


DMA data 
transfer 


Time out. DMA flag and command channel 
flags failed to set within time limit (8 sec). 
(Controller will be preset before retry.) 


E052 


*T0* 
DC, CC-DMA 
LAST WORD 


102052 


DMA output 
(WD, FALL) 


Time out. Data channel and command channel 
flags failed to set within time limit (0.5 sec.) 
after DMA flag set. (Controller will be preset 
before retry.) 


E053 


*T0* DC 


102053 


All disc 
commands 


Time out occurred during automatic status re- 
turn. Data channel flag failed to set within time 
limit (2 sec.). (Controller will be preset before 

retry.) 


E054 


*T0* DC, CC 


102054 


All disc 
commands 


Time out occurred during one of the following: 
password output, command output, non-DCPC 
data transfer, and automatic status return. 
(Controller will be preset before retry.) 


E055 


'DC INTP -- DMA- 


1 02055 


DMA data 
transfer 


Data channel interrupted during DMA transfer 
(controller will be preset before retry.) 
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Table B-1. Error and Information Messages and Halt Codes (Continued) 



MESSAGE 


HALT 
CODE 


PROGRAM 
SECTION 


COMMENTS 


CODE 


TEXT 


H056 


TURN OFF 

MASTER, PRESS 

RUN 


102056 


ERRR 


Turn off controller power. Press RUN. 


H060 


TURN OFF SLAVE, 
PRESS RUN 


102060 


ERRR 


Turn off drive power (any drive except Master). 
Press RUN. 


E061 


PSTS HIGH 


102061 


ERRR 


PSTS line should go low when controller power 
is off. 


H062 


RESTORE 

POWER, PRESS 

RUN 


1 02062 


ERRR 


Turn on controller and drive power. Press RUN. 


H063 


OPEN DOOR, 
PRESS RUN 


102063 


ERRR 


Open drive door. Press RUN. 


H064 


REMOVE DISC, 

CLOSE DOOR, 

PRESS RUN 


102064 


ERRR 


Remove disc from drive, close drive door. 
Press RUN. 


H065 


INSERT PRO- 
TECTED DISC, 
PRESS RUN 


102065 


ERRR 


Insert write-protected disc (or remove write- 
enable tape from current disc). Press RUN. 


H066 


INSERT UNPRO- 
TECTED DISC, 
PRESS RUN 


102066 


ERRR 


Insert write enabled disc. Press RUN. 




None 
None 
None 


102073 
102074 
102075 


Configura- 
tion 

Configura- 
tion 

Test Control 


I/O select code entered at configuration is in- 
valid. Must be greater than 7 (octal). Re-enter 
a valid select code. Press RUN. 
Select code entered during configuration is 
valid. Enter program option bits in S-Register 
and press RUN. 

Test selection request resulting from S-Regis- 
ter bit 9 being set. Enter in the A-Register the 
desired group of tests to be executed. Press 
RUN. 




None 


102076 


Test Control 


End of test halt resulting from S-Register bit 15 
being set (A-Register equals test number). To 
continue, press RUN. 




PASS XXXXXX 


102077 


Test Control 


All selected tests complete. (A-Reglster value 
equals pass count.) S-Register options may be 
changed. To continue, press RUN. 


HiOO 


STAT = XXXXXX 

EXP = YYYYYY 

OP = ZZZZZZ 

TR = XXXX 

SEC = YY 

MODE = ZZZZ 


None 


STAT 


XXXXXX = last status returned by drive con- 
troller (see Appendix A). 
YYYYYY = Expected Status 
ZZZZZZ = Command Code 
XXXX = Track 
YY = Sector 

ZZZZ = Mode: DCPC/Non-DCPC, Interrupts 
on/off, DCPC channel SC (see paragraph 
5-4, MODE). 
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Table B-1. Error and Information Messages and Halt Codes (Continued) 



MESSAGE 


HALT 
CODE 


PROGRAM 
SECTION 


COMMENTS 


CODE 


TEXT 


E100 


STAT = XXXXXX 

EXP = YYYYYY 

OP = ///ZZZ 

TR = XXXX 

SEC = YY 

MODE = 7777 


106000 


All Disc 
Commands 


Same as message HI 00 except that actual 
status does not equal expect-status. Control 
channel flag did not set. (A-Register = OP, 
B-Register = STAT.) 


H101 


NO DMA 


None 


Test 
Control, 
OPDSN 


DCPC (DMA) not available. DCPC operations 
will automatically be converted to equivalent 
non-DCPC operations. 




None 


106002 


TRAK, 
FALL 


Pattern table change request caused by setting 
S-Register bit 2 (see table 5-2). 


El 03 


BAD FORMAT 


106003 


MDIS 


Track 0, sector contains an illegal number of 
good tracks (<1 or >67) or an illegal sector 
offset. Reformat disc. 


1104 


TR XX 
DEFECTIVE 


None 


FALL 


Physical track XX has been marked defective. 
(Logical track no. = physical track no. + no. of 
bad tracks previously discovered.) 




None 


106077 


Test Control 


Halt stored in locations 2 through 77 (octal) to 
trap interrupts which may occur unexpectedly 
because of hardware rrialfunctions. M-Register 
contains the I/O slot number of interrupt. 
Diagnostic may be partially destroyed if halt 
occurs. The program may have to be re- 
loaded; the problem should be corrected be- 
fore proceeding. 


E200 


STAT = XXXXXX 

EXP = YYYYYY 

OP = ZZZZZZ 

TR = XXXX 

SEC = YY 

MODE = ZZZZ 


103000 


All Disc 
Commands 


Same message as HI 00 except that actual 
status does not equal expected status. Control 
channel flag set. (A-Register = OP, B-Regis- 
ter = STAT.) 


E300 


STAT = XXXXXX 
EXP = YYYYYY 

OP = ZZZZZZ 
TR = XXXX 

SEC = YYYY 
MODE = ZZZZ 


107000 


All Disc 
Commands 


Same message as HI 00. Device timed out. 
Status displayed is not valid (it equals contents 
of interface register). Test will be aborted if 
retry count is exceeded. 
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C-1. INTRODUCTION 

The flexible disc has a diameter of 20 cm (7-7/8 inch). It is made with a mylar base which is 
coated with ferromagnetic iron oxide to provide a characteristic quite similar to that of 
magnetic tape. Information is stored on the disc in the form of binary digits represented by 
magnetized points on the disc. The information is stored and retrieved by a read/write head 
that comes in contact with the surface of the disc. Data can be recorded on one side only. 



C-2. DISC FORMAT 

The disc format is shown in figure C-1. Data is stored in concentric tracks on the disc where the 
outside track is track 0. Each disc has a maximum of 67 tracks numbered from through 66. 
The number of available tracks is reduced by the number of bad tracks on the disc. For 
example, if there were two defective tracks, the available tracks would be numbered from 
through 64. 

The disc tracks are divided into 30 pie-shaped sections called sectors numbered physically from 
through 29 numbered logically from to 58 using even numbers only. Each sector can 
contain 256 bytes (or 128 words) of data. The disc sectors can be numbered in one of seven ways 
according to the sector offset specified in the FALL or FTRK statement. The "standard" format 
(sector offset equals 5) places four fill sectors between contiguously numbered sectors (i.e., 0, 6, 
12, 18, 24, 1, 7, 13, 19, 25, 2, etc.). 

The "standard" format optimizes single sector throughput by allowing 22 ms to elapse between 
reading or writing on one sector and reading or writing on the next. As each sector is scanned 
in 5.5 ms, including the scanned sector and four "fill" sectors, a read or write operation takes 
28 ms per sector. The addition of the "fill" sectors provides the software operating system 
enough time to process the 128 words of the sector and be ready for the next 128 words. If the 
data processing has not completed before entering the next sector to be read from or written to, 
the disc must rotate a complete revolution of 167.7 ms, picking up the sector on the next pass. 
If no sector in the sequence is missed on the first pass, then one complete track can be read in 
five disc revolutions taking about 1 second. 

The "fast format" (sector offset equals 1) disc has the 30 sectors sequentially numbered with no 
"fill" sectors. Thus, there is no processing time allowed between sectors and each sector is read 
from or written to in 5.5 ms. To take advantage of this increase in throughput rate requires the 
use of a buffer of substantial size to store the data until it can be processed. The recommended 
buffer size is 1000 words or greater. The diagnostic tests use a large buffer; therefore, the "fast 
format" will allow most tests to run faster. 

Five other values are valid sector offsets as follows: 2, 3, 6, 10, and 15. The sector offset equals 
the number of revolutions required to read each track. Sector numbering for the available 
sector offsets are given in table C-1. 

C-1 



Disc Format and Organization 



DIRECTION OF ROTATION 




NOT TO SCALE 



Figure C-1. Disc Format 
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Disc Format and Organization 



Table C-1. Sequence of Sector Numbers for Available Offsets. 



SECTOR OFFSET 


SEQUENCE OF SECTOR NUMBERS (TRACK 0) 


1 


1 2 3 4 5 6 7 8 9 10 11 12 13 14 




15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 


2 


15 1 16 2 17 3 18 4 19 5 20 6 21 7 22 8 23 9 




24 10 25 11 26 12 27 13 28 14 29 


3 


10 20 1 11 21 2 12 22 3 13 23 4 14 24 




5 15 25 6 16 26 7 17 27 8 18 28 9 19 29 


5 


6 12 18 24 1 7 13 19 25 2 8 14 20 26 




3 9 15 21 27 4 10 16 22 28 5 11 17 23 29 


6 


5 10 15 20 25 1 6 11 16 21 26 2 7 




12 17 22 27 3 8 13 18 23 28 4 9 14 19 24 29 


10 


3 6 9 12 15 18 21 24 27 1 4 7 10 13 16 




19 22 25 28 2 5 8 11 14 17 20 23 26 29 


15 


2 4 6 8 10 12 14 16 18 20 22 24 26 28 




1 3 5 7 9 11 13 15 17 19 21 23 25 27 29 



Sectors on adjacent tracks are offset by "fill" sectors positioned opposite to the direction of 
rotation. The purpose of track-to-track "fill" sectors is to prevent missed sectors when seeking 
sequentially across track boundaries (e.g., from track 1, sector 29 to track 2, sector 0). The 
number of sectors in the track-to-track offset depends upon the sector offset as listed in table 
C-2. This scheme for the diagnostic disc format differs slightly from the DSKET program 
format. 



Table C-2. Sector Offset vs Track-to-Track Offset 



SECTOR OFFSET 


TRACK-TO-TRACK OFFSET 


1 


4 


2 


4 


3 


4 


5 


5 


6 


6 


10 


10 


15 


15 
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HP 12732 FLEXIBLE HISC OIAGNOSTIC 

TEST f*0P)0H 
H0 24 PRESS PRES rr, RUN 
H(124 PPES-S PRESET, RUN 

lESf (•"0('i02 
H043 GOOn TR/'CKSt 0Wo7 
H045 END OF r;iSC 

TEST 00004 
H0bo TURN OFF MASTER, PRESS RUN 
H0O2 RESTORE POl\ER, PRESS TUN 
HOO0 TURN OFF SLAVE, PRESS RUN 
H062 RESTORE POkvER, PRESS RUN 
HM63 OPEN noOR. PRESS RUN 
H064 REMOVE DISC, CLOSE DOOR, PRESS RU^ 
H065 INSERT PROIECIED DISC, PRESS RUN 
H066 INSERT UNPROTECTED DISC, PRESS RU^ 

TEST 00005 

TEST 00(106 

TEST 00007 

TESr 0000H 

H043 GOOD TRACKS: 000 o7 
H045 E^D OF DISC 

H043 GOOD TRACES t 000 o7 
H045 END OF DISC 

TESr 00009 

lESr 00010 
H043 GOOD TRACKS* 00067 

TEST 000 11 
PASS 000001 



D-l/D-2 



THE FOLLOWING PROCRJlM IS ONLY AN EXhMPLE OF THE 
MflCHINE-LEVEL INTERACTION BETUEEH THE COMPUTER 
AND THE FLEXIBLE DISC CONTROLLER. THIS CODE IS 
NOT PART OF THE DISC DIAGNOSTIC PROGRftH. IT IS 
INCLUDED IN THIS HflNUAL OHLV flS HH AID TO UNOER- 
STflNDIHG THE FLEXIBLE DISC/ AND TO FACILITATE THE 
CREATION OF A SPECIAL TEST PROGRAM, SHOULD THE 
NEED ARISE. 

OPERATING PROCEDURE; 

SET P REGISTER TO ADDRESS AT LEFT 

SET A- AHD B-REGISTERS AS INDICATED AT RIGHT 

PRESS RUN 

OPERATION WILL COMPLETE WITH STATUS IN S-REGISTER 

<SEEK AND PRST SET S-REG TO 0) 
PRESS RUN AGAIN TO DO 'READ ZERO SECTORS' COMHAHO 



00100 P E9U PRST 

01000 R EQU READB 

01100 V EflU VRFYB 

6 00 W EQU yRITB 

0500 S EQU SEEKS 

00700 F E9U FTRKB 

00300 T EflU STEP 

00400 M EQU HARK 

01200 EflU DUMPS 

002 00 ■•' EQU STAT 

END 

HO ERRORS *TOTAL **RTE ftSMB 750420** 



A=COUNT, B=hDDR£3S 



A=TRACK, B=3ECT0R 
A=TRACK, B=ADDRESS 



B=ADDRE3S 



ASHB < A / 8/ L 



00100 
00010 

00011 
00002 
00006 
00000 
00000 
00001 
00001 



cc 

DC 

DMAL 

DMAH 

INTP 

A 

B 

3U 



ORG 1006 

EQU loe 

EQU CC+1 

EQU 2B 

EQU eB 

EQU 8 

EQU OB 

EflU IB 

EQU 16 



FLEXIBLE DISC COMMAND COOES 

00100 147777 STATC OCT 147777 

SEEKC OCT 140000 

STEPC OCT 147637 

MARKC OCT 147677 

WRITC OCT 100000 

FTRKC OCT 140036 

REflOC OCT 000000 

'/RFVC OCT 040000 

DUMPC OCT 147737 



00101 140000 

00102 147637 

00103 147677 

00104 100000 

00105 140036 

00106 OOOOOO 

00107 040000 
00110 147737 



STATUS REQUEST 

SEEK 

STEP HEAD IN ONE TRACK 

MARK A TRACK DEFECTIVE 

WRITE DATA OH FLEXIBLE DISC 

FORMAT A TRACK 

READ DATA FROM FLEXIBLE DISC 

READ WITH CLOSE FLUX TRANSITION TOLERANC 

DUMP - READ FROM SECOND SECTOR 
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Minimal Disc Control Routines 

OQ006 ORG DMflH 

00006 024202 JNP STTUS GET STATUS WHEN DHfl INTERRUPTS 

00010 ORG CC GET ERROR STATUS 

00010 024210 JMP ESTftT WHEN CONTROL CHANNEL INTERRUPTS 

00011 124112 JMP STCI RETURN FROM 'STC SUBROUTINE 

WHEN OATft CHANNEL INTERRUPTS 

00 100 ORG 10 OB 

PRESET CONTROLLER 

SEEK HONE OH ALL DRIVES 

SET DISC CHANGE BIT IN STATUS WORD 

00100 0024 4 PR3T CLA,IHfl PRESET CONTROLLER 

00101 102610 OTA CC 

00102 002400 CLA 

00103 102601 OTA SM CLEAR S-REGISTER 

00104 102 610 OTACC 

00105 102100 STF IHTP TURN ON INTERRUPTS 

00106 103710 STC CC,C ENABLE ERROR INTERRUPT 

GOlOr 014112 JSB STC CLEAR DATA CHANNEL %, WAIT FOR COHPLETIOH 

00110 102004 HLT 4 

00111 024201 JMP RO READ ZERO SECTORS IF RESTARTED 

00112 000000 STC NOP OUTPUT A-REGISTER AND SET CONTROL ON DC 

00 1 13 1026 1 1 OTA DC 

114 10 3 7 11 3 T C D C , C 

00115 Q24115 JMP * UAIT FOR INTERRUPT 

00200 ORG 2006 

STATUS REQUEST COMMAND 

00200 060100 STAT LDA STATC STATUS REQUEST COMMAND 

00201 014226 RO JSB COMNO OUTPUT COMMAND 

00202 060225 STTUS LDA 2 

00203 102610 OTA CC OUTPUT CTLO TO TERMINATE PARTIAL SECTOR 

00204 002006 IHA.SZA UAIT AT LEAST 32 MICROSECONDS 

00205 024204 JMP *-l TO MAKE SURE CTLO IS RECOGNIZED 

00206 102311 SFS DC UAIT FOR FLEXIBLE DISC COMPLETION <DMfl U 

00207 024206 JMP *-l 

00210 i0311i ESTAT CLF DC INHIBIT IHTERkUPT HERE 

00211 106706 CLC D«AH TURN OFF DMA <IN CASE OF ERROR; 

00212 102106 STF DMAH 

00213 002400 CLA 

00214 103710 STC CCC ENABLE CONTROL CHANNEL INTERRUPT 

00215 014112 JS8 STC REQUEST STATUS 

00216 102511 LIA DC INPUT STATUS 

00217 102601 OTA SW OUTPUT TO S-REGISTER 

00220 002400 CLA 

00221 102610 OTA CC CLEAR CONTROL CHANNEL 

00222 014112 JSB STC ACKNOWLEDGE STATUS 

00223 102000 HLT 

00224 024201 JMP RO IF RESTARTED OUTPUT READ ZERO SECTORS' 



00225 00 00 02 .2 OCT 



00226 000000 COHND NOP OUTPUT PASSWORD AND COMMAND 

00227 Q3024Q I OR DRIV ADD DRIVE NO. TO COMMAND 

00230 070241 STA TEMP 

00231 060242 LDA FASSH 

00232 102100 STF INTP TURN ON INTERRUPTS 

00233 103710 STC C C ■ C ENABLE ERROR INTERRUPT 

00234 014112 JSB STC OUTPUT PASSyORD 

00235 060241 LDA TEMP 

00236 014112 JSB STC OUTPUT COMMAND 

00237 124226 JMP COHND • I 
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Minimal Disc Control Routines 



00240 000000 DRIV NOP DRIVE NUMBER IN BITS 12 t 13 

00241 000000 TEHP NOP 

00242 127207 PASSU OCT 127207 CONTROLLER PASSWORD 

00 3 00 0RG30Qe 

STEP HEAD IN ONE PHYSICAL TRACK 

<«flY POSITION HEAD OVER DEFECTIVE OR UHFORHATTED TRACK) 

SHOULD BE FOLLOWED BY PRESET BEFORE CONTINUING 

WITH DATA TRANSFER COMHAHDS 

00300 060102 STEP LOA STEPC STEP HEAD IN 1 TRACK 

00301 024201 ..IMP RO 



00400 ORG 400B 

MARK A TRACK DEFECTIVE 

CONTROLLER WILL AUTOMATICALLY SKIP THIS TRACK OH SEEK 

00400 060103 MARK LDA MARKC MARK TRACK DEFECTIVE 

00401 2420! JHPRO 



00500 ORG 50QB 

SEEK TRACK AND SECTOR 

(TRACK IN A-REG, SECTOR IN B-REG) 

NO HEAD MOVEHENT OCCURS UNTIL DATA TRANSFER COMMAND IS OUTPUT 

00500 074514 SEEKB STB SECTR SECTOR IN B 

00501 070513 SEEKA STA TRACK TRACK IN A 

00502 060513 SEEK LDA TRACK SEEK TRACK AND SECTOR 
0050 3 1722 ALF.RAL 

00504 030514 I OR SECTR 

00505 030101 lOR 3EEKC 

00506 014226 JSB COMND OUTPUT COMMAND 

00507 002400 CLA 

00510 102601 OTA SW CLEAR S-REG 

00511 102001 HLT 1 

00512 024201 JHP RO READ ZERO SECTORS IF RESTARTED 



005 13 QOOOOn TRACK HOP 
005 14 000000 SECTR NOP 

00600 ORG 600B 

WRITE DATA OH FLEXIBLE DISC 

(WORD COUNT IN A-REG, BUFFER ADDRESS IN B-REG) 

DMA CHANNEL 6 

00600 074615 URITB STB OTBF BUFFER ADDRESS IN B 

00601 070616 WRITA STA COUNT WORD COUNT <P03ITIVE) IN A 

00602 060616 WRIT LDA COUNT WRITE DATA OH FLEXIBLE DISC 

00603 014617 OSB DMAO SET UP DMA WRITE 

00604 060616 LDA COUNT 

00605 006400 CLE 

00606 101107 RRR 7 DIVIDE INTO SECTORS 

00607 006002 S2B 

00610 002004 INA IF PARTIAL SECTOR, ROUND UP 

00611 030104 lOR WRITC 

00612 014226 FEHT JSB COMND OUTPUT COMMAND 

00613 103706 STCDMAH-C START DMA 

00614 024614 JNP * WAIT FOR INTERRUPT 



00615 011000 OTBF DEF OTBUF ADDRESS OF OUTPUT BUFFER 

00616 000200 COUNT DEC 128 ONE SECTOR 
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Minimal Disc Control Routines 

00617 000000 DMflO NOP SE7 UP DMA WRITE 

00620 102702 3TC DMflL 

00621 003004 CNft-INfl NEGATE MORO COUNT 

00622 102602 OTfl DMaL OUTPUT TO OMh REGISTER 

00623 106702 CLC DMhL 

00624 060615 LDA OTBF 

00625 102602 OTA DMHL OUTPUT rtOORESS 

00626 060632 LDA DftTCH 

00627 030104 lOR SIGH SET CONTROL AFTER EhCH WORD 

00630 102606 OTh DMflH OUTPUT DC SELECT CODE 

00631 124617 JHP DMflO,! 

00632 OOOOll DATCH ASS OC DATA CHANNEL SELECT CODE 
00104 SIGN £i3U (JRITC SIGN BIT 

00700 ORG 7oae 

FORMAT rt TRACK 

(TRACK IN A-REG, BUFFER ADDRESS IN B-REG) 
HO HEAD MOVEHENT OCCURS 

SECTORS HAY BE NUMBERED IN ANY ORDER BY ALTERRIHG 
THE FIRST 30 WORDS OF THE BUFFER 

00700 074615 FTRkB STB OTBF BUFFER ADDRESS IN B 

0070 1 7 0? 13 FTRKA STA TRACK TRACK IN A 

00702 060615 FTRK LDA OTBF FORMAT A TRACK 

00703 070241 STA TEMP 

00704 006400 CLB 

00705 060722 LDA H3Q NO. OF SECTORS PER TRACK 

00706 07061? STA TEHP2 

707 1^4241 STB TEMP, I NU,MBER SECTORS FROM TO 29 

00710 006004 IN6 

00711 034241 ISZ TEMP BUMP ADDRESS 
0712 034617 ISZ TEMP2 

00713 247 7 ,IHP*-4 

00714 3004 C«A,INA WAKE POSITIVE 

00715 QMei:" JSB DMhO SET UP DMA WRITE 
007 16 060513 LDA TRACK 

717 1722 ALF,RAL POSITION TRACK BITS 

00720 030105 i OR FTRKC ADD FORMAT COMMAND 

00721 024612 ..IMP FEHT GO OUTPUT COMMAND 

006 17 TEMP2 EQU DHAO 

00722 17774 2 (13 DEC -30 

01000 ORG100 8 

READ DATA FROM FLEXIBLE DISC 

(WORD COUNT IN A-REG, BUFFER ADDRESS IN B-REG> 

DMA CHAHNEL 6 

01000 075023 READB STB IN8F BUFFER ADDRESS IN B 

01001 070616 READA STA COUNT WORD COUNT (POSITIVE) IN A 

01002 060106 READ LDA READC 

01003 07 1024 STA VFV READ/VERIFY COMMAND 

01004 060616 LDA COUNT 

01005 00200 3 SZA,RSS 

01006 024201 ..IMP RO READ-ZERO-SECTORS 
1007 15025 OSB DMA I SET UP DMA READ 

01010 060616 LDA COUNT 

01011 006400 CLB 

10 12 10 110 7 R R R 7 DIVIDE INTO SECTORS 

01013 6002 S26 

01014 002004 INA IF PARTIAL SECTOR, ROUND UP 

01015 031024 lORVFY ADD COMMAND 

01016 014226 DENT JSB COMND OUTPUT COMMAND 

01017 002400 CLA 

01020 103611 OTA DC,C MAKE SURE FLAG IS CLEAR 

01021 103706 3TC DMAH,C START DMA 

01022 014112 JSB STC START FIRST «ORD TRANSFER & WAIT FOR INT 
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Minimal Disc Control Routines 

01023 002000 INBF DEF INBUF BUFFER HDDfiESS 

01024 000000 VFY NOP VERIFY OR PESD CONMflND CODE 

01025 000000 OMfll NOP SET UP OMfl READ 

01026 102702 3TC DMflL 

0102? 003004 C«H/IH« NEGATE COUNT 

01030 102602 OTA DMflL OUTPUT TO DMrt REGISTER 

01031 106702 CLC DMhL 

01032 061023 LDfi INBF 

01033 030104 !0R SIGH SET INPUT SIT 

01034 102602 OTft DM:ifL OUTPUT BUFFER ADURESS 

01035 060632 LDA DftTCH 

01036 030104 lOfi SIGN SET CONTROL AFTER EACH UORD 

01037 102606 OTA OHAH SEND SELECT CODE OF DC 
010 40 12 50 25 JHP DMA! , I 

on 00 ORG I lOOB 

VERIFY -- READ WITH CLOSE FLUX TRANSITION TOLERANCES 
<«ORD COUNT IN A-REG, BUFFER ADDRESS IN B-REG> 
DMA CHANNEL i 

01100 075023 VRFYB STB INBF BUFFER ADDRESS IN 6 

01101 Q70616 VRFYA STA COUNT UORD COUNT (POSITIVE) IN A 

01102 060107 VRFY LOA VRFYC VERIFY DATA <READ TO INPUT BUFFER) 

01103 025003 JHP READ+1 

01200 ORG 1200B 

DUHP -- READ FROH SECTOR PHYSICALLY FOLLOWING CURRENT SECTOR 

USED TO RECOVER DATA FROM SECTOR WHOSE SECTOR ADDRES-S IS UNREADABLE 

(BUFFER ADDRESS IN B-REG, ALWAYS READS 128 WORDS) 

HO HEAD MOVEMENT OCCURS 

01200 Q75023 DUMPS STB INBF BUFFER ADDRESS IN B 

01201 061205 DUMP LOA D128 DUMP 128 WORDS FROfl SECOND SECTOR 

01202 015025 JSB DMAI SET UP DMA READ 

01203 06 110 LOA DUMPC 

01204 02501b ..IMP DENT GO OUTPUT COMMAND 



01205 000200 0128 DEC 128 



02000 ORG 20Q0B 

02000 000000 INBUF BSS 7000B 

11000 000000 OTBUF BSS 70006 
20000 NEXT EQU * END OF 8 K MEMORY 
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